/* 封装axios用于发送请求 */
import axios from 'axios'
import store from '@/store/index'
import { Message } from 'element-ui'
import router from '../router'
// 创建一个新的axios实例
const request = axios.create({
    baseURL: 'http://interview-api-t.itheima.net/',
    timeout: 5000
})

// 添加请求拦截器
request.interceptors.request.use(function(config) {
    // 处理token
    const token = store.state.users.token
    if (token) {
        config.headers.Authorization = `Bearer ${token}`
    }
    return config
        // 在发送请求之前做些什么
}, 

function(error) {
    // 对请求错误做些什么
    if (error.response) {
        if (error.response.status === 401) {
            // 给提示，清除无效token(vuex+本地)，拦到登录
            Message.error('尊敬的用户，当前登录状态已过期！')

            // 提交清除token的mutation
            store.commit('users/logout')

            // 跳转到登录
            router.push('/login')
        } else {
            // 给提示
            Message.error(error.response.data.message)
        }
    }
    return Promise.reject(error)
})

// 添加响应拦截器
request.interceptors.response.use(function(response) {
    // 对响应数据做点什么
    return response.data
}, function(error) {
    // 对响应错误做点什么
    return Promise.reject(error)
})

export default request